首页 > 试题广场 >

寻找第K大

[编程题]寻找第K大
  • 热度指数:353681 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 256M,其他语言512M
  • 算法知识视频讲解

有一个整数数组,请你根据快速排序的思路,找出数组中第 k 大的数。

给定一个整数数组 a ,同时给定它的大小n和要找的 k ,请返回第 k 大的数(包括重复的元素,不用去重),保证答案存在。
要求:时间复杂度 ,空间复杂度
数据范围:,数组中每个元素满足
示例1

输入

[1,3,5,2,2],5,3

输出

2
示例2

输入

[10,10,9,9,8,7,5,6,4,3,4,2],12,3

输出

9

说明

去重后的第3大是8,但本题要求包含重复的元素,不用去重,所以输出9        
#
# 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
#
# 
# @param a int整型一维数组 
# @param n int整型 
# @param K int整型 
# @return int整型
#
class Solution:
    def findKth(self , a: List[int], n: int, K: int) -> int:
        # write code here
        import heapq
        res = ""
        if n >= K:
            qp = []
            for i in range(K):
                heapq.heappush(qp, a[i])
            for i in range(K, n):
                if a[i] > qp[0]:
                    heapq.heapreplace(qp, a[i])
            res = qp[0]
        return res

发表于 2023-07-02 13:02:15 回复(0)
#
# 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
#
# 
# @param a int整型一维数组 
# @param n int整型 
# @param K int整型 
# @return int整型
#
class Solution:
    def findKth(self , a: List[int], n: int, k: int) -> int:
        # write code here       
        res=[]
        if n< k&nbs***bsp;n<=0:
            return res
        else:
            import heapq
            q=[]
            for i in range(k):#构建小顶堆
                heapq.heappush(q,a[i])
            for i in range(k,n):
                if q[0] < a[i]:#最大的k个里面的最小的,
                    heapq.heapreplace(q,a[i])
            res=heapq.heappop(q)#堆顶元素就是第k大
            return res
    

发表于 2022-08-20 11:32:13 回复(1)
class Solution:
    def findKth(self , a: List[int], n: int, K: int) -> int:
        # write code here
        import heapq
        return heapq.nlargest(K, a)[-1]

发表于 2022-08-14 09:28:53 回复(0)
class Solution:
    def findKth(self , a: List[int], n: int, K: int) -> int:
        # write code here
        if not a: return None
        if K > len(a): return None
        a.sort()
        a.reverse()
        return a[K-1]

发表于 2022-07-26 21:34:04 回复(0)

请问各位大佬,我的“快速排序”怎样修改才能不超时?

class Solution:
def findKth(self , a: List[int], n: int, K: int) -> int:
# write code here

    if len(a) == 0:
        return None

    def partition(a,l,r):
        p = l
        for i in range(l,r):
            if a[i] > a[r]:
                a[i],a[p] = a[p],a[i]
                p += 1
        a[r],a[p] = a[p],a[r]  
        return p
    def quick_sort(a,left,right):
        if left < right:
            pos = partition(a,left,right)
            quick_sort(a,left, pos-1)
            quick_sort(a,pos+1, right)       

    quick_sort(a, 0, len(a)-1)
    return a[K-1]
发表于 2022-07-19 20:20:21 回复(0)
这道题的样本就很不合理,取列表第一个元素做为中间值对比就超时
发表于 2022-07-16 20:55:02 回复(0)
Python就是一行代码的事情,排个序基本就行了


发表于 2022-06-25 18:21:55 回复(0)
class Solution:
    def findKth(self , a: List[int], n: int, K: int) -> int:
        # write code here
        a=sorted(a,reverse=True)
#         print(a)
        return a[K-1]

不讲理

发表于 2022-06-08 17:36:44 回复(0)

利用快排思想 + 随机初始化基数,不初始化用例过不了

import random
class Solution:
    def partition(self, a, low, high):
        m =random.randrange(low, high+1)
        a[low], a[m] = a[m], a[low]
        temp = a[low]
        while low < high:
            while low < high and a[high] < temp:
                high -= 1
            a[low] = a[high]
            while low < high and a[low] >= temp:
                low += 1
            a[high] = a[low]
        a[low] = temp
        return low
    def quick_sort(self, a, low, high, k):
        p = self.partition(a, low, high)
        if p-low+1 == k:
            return a[p]
        elif p-low+1 > k:
            return self.quick_sort(a, low, p-1, k)
        else:
            return self.quick_sort(a, p+1, high, k-(p-low+1))

    def findKth(self , a: List[int], n: int, K: int) -> int:
        return self.quick_sort(a, 0, n-1, K)
发表于 2022-05-18 15:31:53 回复(1)
# 方法一,采用python内置的sort函数,虽然很讨巧,但是能通过,而且效率也还行
class Solution:
    def findKth(self , a: List[int], n: int, K: int) -> int:
        # write code here
        # 对a进行快速排序
        a.sort()
        #print(a)
        #print(a[-K])
        return a[-K]

# 方法二:本质按照题目的思想,时间复杂度O(N),空间复杂度O(1),采用堆排序的思路
# 自己建堆的效率果然还是比不上系统内置的sort(),虽然也能够勉强AC
# 但是如果是自己用partttion+二分法写快排是一定会超时的,也看到题解有将pivot设置成随机数通过的
# 以下为自建堆排序的代码
class Solution:
    def findKth(self , a: List[int], n: int, K: int) -> int:
        # write code here
        def KeepHeap(arr, parent, high):
            # 假设只有根节点需要调整,两棵子树都是堆
            child = parent *2 +1 #child 指向i的左子树
            temp = arr[parent]
            while child <high:
                # 获取根以及左右子节点的最大值
                # 先比较左右子节点的值
                # 右子树比较大,则指向右子树
                if child+1< high and arr[child] < arr[child+1]:
                    child +=1
                # 如果父节点的值已经大于孩子节点的值,说明在正确位置上
                # 直接结束
                if temp >=arr[child]:
                    break
                # 如果左右字子节点的值大于父节点,将最大值赋给根节点
                arr[parent] = arr[child]
                parent = child
                # 子节点发生变化,从它的左子节点开始
                child = 2 * parent + 1
            # 将temp值放到最终的位置
            arr[parent]=temp   
        def Heap_Sort(arr):
            # 1、建堆
            # 根据升序降序需求选择大顶堆和小顶堆,这采用的大顶堆,最后是升序的序列
            # 先找到最后一个不是叶子节点的根节点
            # 再向上循环根节点,从小到大
            n = len(arr)
            for i in range(n//2-1, -1, -1):
                KeepHeap(arr,i,n)

            # 2、挨个出数,按升序排列
            # 将堆顶元素与末尾元素交换,将最大元素”沉”到数组末端,此时数组末端存储了当前区间最大的元素
            for i in range(n-1, -1, -1):
                arr[0], arr[i] = arr[i], arr[0]
                KeepHeap(arr, 0, i)
        Heap_Sort(a)
        #print(a)
        return a[-K]

发表于 2022-05-07 00:07:48 回复(0)
class Solution:
    def findKth(self , a: List[int], n: int, K: int) -> int:
        # write code here
        return sorted(a,reverse=True)[K-1]

发表于 2022-04-25 09:38:45 回复(0)
    def findKth(self , a: List[int], n: int, K: int) -> int:
        # write code here
        #         a.sort()
        def quickSort(arr):
            if len(arr) < 2: return arr
#             pivot = arr[0]
            pivot = arr[len(arr) // 2]  # 使用向下取整能够通过所有测试用例.
            left = [x for x in arr if x < pivot]
            middle = [x for x in arr if x == pivot]
            right = [x for x in arr if x > pivot]
            
            return quickSort(left) + middle + quickSort(right)
        a = quickSort(a)
        return a[-K]
快排,再返回倒数第K个值。
发表于 2022-04-23 12:31:39 回复(0)
快排,二分,python3确定能跑得过么。。。。
发表于 2022-03-24 14:19:34 回复(0)
快排寻找第K大:
class Solution:
    def sort(self, num, start, end):
        if start >= end: return
        pivot = end
        left, right = start, end
        while left < right:
            while left < right and num[left] <= num[pivot]: left += 1
            while left < right and num[right] > num[pivot]: right -= 1
            num[left], num[right] = num[right], num[left]
        num[left], num[pivot] = num[pivot], num[left]
        return pivot
        
    def quickSort(self, num, start, end, n, K):
        pivot = self.sort(num, start, end)
        if pivot == n - K:
            return num[pivot]
        elif pivot < n-K:
            return self.quickSort(num, pivot+1, end, n, K)
        else:
            return self.quickSort(num, start, pivot-1, n, K)

    def findKth(self, a, n, K):
        # write code here
        res = self.quickSort(a, 0, n-1, n, K)
        return res


发表于 2022-03-09 21:47:44 回复(0)
class Solution:
    def findKth(self , a: List[int], n: int, K: int) -> int:
        for i in range(n - 1):
            for j in range(i + 1, n):
                if a[i] < a[j]:
                    a[i], a[j] = a[j], a[i]
        return(a[K - 1])

发表于 2021-12-31 16:24:18 回复(0)